<template>
  <div class="wrapper">
    <!-- 卡片组件 -->
    <card
      :_Title="$t('myOrders')"
      :_Size="16"
      :_Tabs="changeWay"
      @_Change="change"
      v-if="!homePage"
    ></card>
    <card
      :_Title="$t('myOrders')"
      :_Size="16"
      :_Tabs="changeWay"
      @_Change="change"
      :_More="$t('all') + $t('orders')"
      _Src="/home/MyOrder"
      v-else
    ></card>
    <!-- 搜索 筛选 -->
    <div class="mb_24 box" v-if="!homePage">
      <div class="global_float_right">
        <Input
          class="width_300"
          search
          enter-button
          v-model="params.keywords"
          @on-search="getList"
          :placeholder="$t('pleaseEnter') + '订单号搜索'"
        />
      </div>
    </div>
    <!-- 订单列表 -->
    <empty v-if="orderList.length === 0" />
    <div class="order-content" v-else>
      <div
        class="order-list"
        v-for="(order, onderIndex) in orderList"
        :key="onderIndex"
      >
        <div class="order-header">
          <div>
            <div>{{ filterOrderStatus(order.orderStatus) }}</div>
            <div>
              订单号：{{ order.sn }} &nbsp; &nbsp; &nbsp;{{ order.createTime }}
            </div>
          </div>
          <div>
            <Button
              v-if="order.orderStatus === 'COMPLETED'"
              @click="delOrder(order.sn)"
              class="del-btn mr_10 fontsize_16"
              style="margin-top: -5px"
              type="text"
              icon="ios-trash-outline"
              size="small"
            ></Button>
            <span>{{ order.flowPrice | unitPrice("$") }}</span>
          </div>
        </div>
        <div class="order-body">
          <div class="goods-list">
            <div
              v-for="(goods, goodsIndex) in order.orderItems"
              :key="goodsIndex"
            >
              <img
                @click="goodsDetail(goods.skuId, goods.goodsId)"
                class="hover-color"
                :src="goods.image"
                alt=""
              />
              <div>
                <div
                  class="hover-color"
                  @click="goodsDetail(goods.skuId, goods.goodsId)"
                >
                  {{ goods.name }}
                </div>
                <div class="mt_10">
                  <span class="global_color"
                    >{{ goods.goodsPrice | unitPrice("$") }} </span
                  >x {{ goods.num }}
                  <span style="margin-left: 10px; color: #ff9900">{{
                    refundPriceList(goods.isRefund)
                  }}</span>
                </div>

                <Button
                  v-if="goods.complainStatus == 'NO_APPLY'"
                  @click="complain(order.sn, goodsIndex)"
                  type="warning"
                  class="fontsize_12"
                  size="small"
                  style="position: relative; top: -22px; left: 190px"
                  >投诉</Button
                >
              </div>
            </div>
          </div>
          <div>
            <span @click="shopPage(order.storeId)">{{ order.storeName }}</span>
          </div>
          <div>
            <!-- 订单基础操作 -->
            <Button @click="orderDetail(order.sn)" type="info" size="small"
              >{{ $t("orders") }}详情</Button
            >
            <!-- <Button
              @click="handleCancelOrder(order.sn)"
              type="error"
              v-if="order.allowOperationVO.cancel"
              size="small"
              >{{ $t("cancel") }}{{ $t("orders") }}</Button
            > -->
            <Button
              @click="goPay(order.sn)"
              size="small"
              type="success"
              v-if="order.allowOperationVO.pay"
              >去支付</Button
            >
            <Button
              @click="received(order.sn)"
              size="small"
              type="warning"
              v-if="order.allowOperationVO.rog"
              >确认收货</Button
            >
            <!-- 售后 -->
            <Button
              v-if="
                order.groupAfterSaleStatus &&
                (order.groupAfterSaleStatus.includes('NOT_APPLIED') ||
                  order.groupAfterSaleStatus.includes('PART_AFTER_SALE'))
              "
              @click="showPhoneNumber()"
              size="small"
              >申请售后</Button
            >
          </div>
        </div>
      </div>
      <Spin size="large" fix v-if="spinShow"></Spin>
    </div>
    <!-- 分页 -->
    <div class="page-size" v-if="!homePage">
      <Page
        :total="total"
        @on-change="changePageNum"
        @on-page-size-change="changePageSize"
        :page-size="params.pageSize"
        show-total
        show-sizer
      >
      </Page>
    </div>
    <!-- 选择售后商品 -->
    <Modal v-model="afterSaleModal" title="请选择申请售后的商品">
      <div>
        <Table
          border
          :columns="afterSaleColumns"
          :data="afterSaleArr"
          @on-row-click="afterSaleSelect"
        >
        </Table>
      </div>
      <div slot="footer"></div>
    </Modal>
    
    <!-- 售后电话号码弹窗 -->
    <Modal v-model="phoneNumberModal" title="售后服务电话">
      <div class="phone-number-container">
        <p>请拨打以下电话联系客服：</p>
        <p class="phone-number">+1 6472739168</p>
      </div>
    </Modal>
    
    <Modal
      v-model="cancelAvail"
      title="请选择取消订单原因"
      @on-ok="sureCancel"
      @on-cancel="cancelAvail = false"
    >
      <RadioGroup
        v-model="cancelParams.reason"
        vertical
        type="button"
        button-style="solid"
      >
        <Radio :label="item.reason" v-for="item in cancelReason" :key="item.id">
          {{ item.reason }}
        </Radio>
      </RadioGroup>
    </Modal>
  </div>
</template>

<script>
import { getOrderList, sureReceived, cancelOrder, delOrder } from "@/api/order";
import { afterSaleReason } from "@/api/member";
import { orderStatusList } from "../enumeration.js";
export default {
  name: "MyOrder",
  props: {
    homePage: {
      // 判断是否个人中心首页展示内容
      type: Boolean,
      default: false,
    },
  },
  data() {
    return {
      orderList: [], // 订单列表
      params: {
        // 请求参数
        pageNumber: 1,
        pageSize: 10,
        // orderStatus: 'ALL',
        keywords: "",
        tag: "ALL",
      },
      cancelParams: {
        // 取消售后参数
        orderSn: "",
        reason: "",
      },
      // 状态数组
      orderStatusList,
      changeWay: [
        this.$t("all") + this.$t("orders"),
        this.$t("pendingPayment"),
        this.$t("toBeReceived"),
        this.$t("done"),
      ], // 订单状态
      total: 0, // 数据总数
      spinShow: false, // 加载状态
      afterSaleModal: false, // 选择售后商品模态框
      phoneNumberModal: false, // 售后电话号码模态框
      afterSaleColumns: [
        // 售后商品表头
        { title: this.$t("goods") + "名称", key: "name" },
        { title: "价格", key: "goodsPrice" },
      ],
      afterSaleArr: [], // 售后商品列表
      cancelAvail: false, // 取消订单modal控制
      cancelReason: [], // 取消订单原因
    };
  },
  mounted() {
    if (this.homePage) this.params.pageSize = 5;
    this.getList();
  },
  methods: {
    // 退款状态枚举
    refundPriceList(status) {
      switch (status) {
        case "ALL_REFUND":
          return this.$t("all") + "退款";
        case "PART_REFUND":
          return this.$t("partial") + "退款";
        case "NO_REFUND":
          return "";
        case "REFUNDING":
          return "退款中";
        default:
          return "";
      }
    },
    goodsDetail(skuId, goodsId) {
      // 跳转商品详情
      let routeUrl = this.$router.resolve({
        path: "/goodsDetail",
        query: { skuId, goodsId },
      });
      window.open(routeUrl.href, "_blank");
    },
    // 切换订单状态
    change(index) {
      switch (index) {
        case 0:
          this.params.tag = "ALL";
          break;
        case 1:
          this.params.tag = "WAIT_PAY";
          break;
        case 2:
          this.params.tag = "WAIT_ROG";
          break;
        case 3:
          this.params.tag = "COMPLETE";
          break;
      }
      this.getList();
    },
    // 跳转店铺首页
    shopPage(id) {
      let routeUrl = this.$router.resolve({
        path: "/Merchant",
        query: { id: id },
      });
      window.open(routeUrl.href, "_blank");
    },
    orderDetail(sn) {
      // 跳转订单详情
      this.$router.push({ name: "OrderDetail", query: { sn } });
    },
    received(sn) {
      // 确认收货
      sureReceived(sn).then((res) => {
        if (res.success) {
          this.$Message.success("确认收货成功");
          this.getList();
        }
      });
    },
    goPay(sn) {
      // 去支付
      this.$router.push({
        path: "/payment",
        query: { orderType: "ORDER", sn },
      });
    },
    // 显示售后电话号码
    showPhoneNumber() {
      this.phoneNumberModal = true;
    },
    
    applyAfterSale(goodsItem) {
      // 申请售后 - 现在改为显示电话号码
      this.showPhoneNumber();
      // 以下代码保留但不再使用
      /*
      let arr = [];
      goodsItem.forEach((e) => {
        if (
          e.afterSaleStatus === "NOT_APPLIED" ||
          e.afterSaleStatus === "PART_AFTER_SALE"
        ) {
          arr.push(e);
        }
      });
      if (arr.length === 1) {
        this.$router.push({ name: "ApplyAfterSale", query: { sn: arr[0].sn } });
      } else {
        this.afterSaleArr = arr;
        this.afterSaleModal = true;
      }
      */
    },
    // 申请售后
    afterSaleSelect(item) {
      this.$router.push({ name: "ApplyAfterSale", query: { sn: item.sn } });
    },

    complain(sn, goodsIndex) {
      // 投诉
      this.$router.push({ name: "Complain", query: { sn, index: goodsIndex } });
    },
    delOrder(sn) {
      // 删除订单
      this.$Modal.confirm({
        title: this.$t("delete") + this.$t("orders"),
        content: "<p>确认删除当前订单吗？</p>",
        onOk: () => {
          delOrder(sn).then((res) => {
            if (res.success) {
              this.$Message.success(this.$t("delete") + this.$t("succeed"));
              this.getList();
            }
          });
        },
        onCancel: () => {},
      });
    },
    getList() {
      // 获取订单列表
      this.spinShow = true;
      let params = JSON.parse(JSON.stringify(this.params));
      if (params.orderStatus === "ALL") {
        delete params.orderStatus;
      }
      getOrderList(params).then((res) => {
        this.spinShow = false;
        if (res.success) {
          this.orderList = res.result.records;
          this.total = res.result.total;
        }
      });
    },
    changePageNum(val) {
      // 修改页码
      this.params.pageNumber = val;
      this.getList();
    },
    changePageSize(val) {
      // 修改页数
      this.params.pageNumber = 1;
      this.params.pageSize = val;
      this.getList();
    },
    handleCancelOrder(sn) {
      // 取消订单
      this.cancelParams.orderSn = sn;
      afterSaleReason("CANCEL").then((res) => {
        if (res.success) {
          this.cancelReason = res.result;
          this.cancelAvail = true;
          this.cancelParams.reason = this.cancelReason[0].reason;
        }
      });
    },
    sureCancel() {
      // 确定取消
      cancelOrder(this.cancelParams).then((res) => {
        if (res.success) {
          this.$Message.success(
            this.$t("cancel") + this.$t("orders") + this.$t("succeed")
          );
          this.getList();
          this.cancelAvail = false;
        }
      });
    },
    filterOrderStatus(status) {
      // 获取订单状态中文
      const ob = this.orderStatusList.filter((e) => {
        return e.status === status;
      });
      return ob && ob[0] ? ob[0].name : status;
    },
  },
};
</script>

<style scoped lang="scss">
.wrapper {
  margin-bottom: 40px;
}
.box {
  overflow: hidden;
}
.page-size {
  margin: 15px 0px;
  text-align: right;
}
/** 订单列表 */
.order-list {
  border: 1px solid #ddd;
  border-radius: 3px;
  margin-bottom: 10px;

  &:hover {
    .del-btn {
      visibility: visible;
    }
  }
  .del-btn {
    visibility: hidden;
  }

  .order-header {
    display: flex;
    align-items: center;
    padding: 10px;
    justify-content: space-between;
    border-bottom: 1px solid #ddd;
    > div:nth-child(1) > div:nth-child(2) {
      font-size: 12px;
      color: #999;
      margin-top: 3px;
    }
  }
  .order-body {
    display: flex;
    justify-content: space-between;
    color: #999;
    padding: 10px;

    .goods-list > div {
      width: 500px;
      display: flex;
      margin-bottom: 10px;
      img {
        width: 60px;
        height: 60px;
        margin-right: 10px;
      }
      > div {
        flex: 1;
      }
    }

    > div:nth-child(2) {
      width: 150px;
      text-align: center;
      span {
        color: #438cde;
        cursor: pointer;
        &:hover {
          color: $theme_color;
        }
      }
      .ivu-icon {
        color: #ff8f23;
        cursor: pointer;
        &:hover {
          color: $theme_color;
        }
      }
    }

    > div:nth-child(3) {
      width: 100px;
      .ivu-btn {
        margin-bottom: 10px;
      }
    }
  }
}
.phone-number-container {
  text-align: center;
  padding: 20px 0;
  
  .phone-number {
    font-size: 24px;
    font-weight: bold;
    color: #438cde;
    margin-top: 10px;
  }
}
</style>
